Oracle® Fusion Middleware 

Supplemental Instructions for Running Fusion Order Demo for Oracle SOA Suite 
11 g Release 1 (11.1.1.7.0) 

April 2013 


This tutorial assumes you have installed, configured, and deployed Fusion Order 
Demo, as specified in Chapter 3 of the Oracle Fusion Middleware Developer's Guide for 
Oracle SOA Suite. Specifically, this tutorial complements Section 3.6, "Running Fusion 
Order Demo." You can find the Oracle Fusion Middleware Developer's Guide for Oracle 
SOA Suite on Oracle Technology Network: 

http://www.oracle.com/pls/asllll70/lookup?id=SOASE 


Running Fusion Order Demo 

You begin the ordering process in the Store Front UI, where a user shops for and 
orders products. When an order is submitted, the Application Development 
Framework Business Component writes the order to the database and raises a 
NewOrderSubmitted business event using the Events Delivery Network (EDN). The 
OrderPendingEvent mediator subscribes to this event, and initiates the main BPEL 
process, OrderProcessor, to process the order. 


Task 1: Place Two Orders in the Store Front 

In this task, place two orders, one for under $2000 and the other for over $2000. By 
placing these orders, you can see how orders totalling more than $2000 require human 
approval. 

To place orders: 

1. Access the Store Front from the following URL: 

http:/ /hostname:por t/StoreFrontModule/faces/home.j spx 

where hostname is the DNS name or IP address of the Oracle WebLogic Server 
for Oracle SOA Suite and port is the address of the port, for example, port 8001, 
on which the Store Front module is deployed. 

You begin the order process by browsing the product catalog. When you click Add 
next to a product, the site updates the shopping cart region to display the item. 

2 . Place an order for under $2000: 

a. Click Add under Tre 650 Phone/PDA for $299.99. 

b. Click Add under Bluetooth Phone Headset for $49.99. 

Figure 1 shows the cart summary with the two products added. The summary 
displays a subtotal purchase total of $349.98 for the two items that appear in 
the cart. 
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Figure 1 Shopping Part Summary 


Shopping Cart Sum maty 


Bluetooth Phone Headset 
Cell Phones 

49.99 - quantity: 1 
Treo 650 Phone/PDA 

Cell Phones 

199.99 - quantity: 1 


[ I 

Subtotal 349.98 


c. Click the Checkout link (Figure 2), located in the middle of the menu bar. 


Figure 2 Checkout Link 


jtl My Orders Checkout Registration 


A login dialog is displayed (Figure 3). 

Figure 3 Log In Dialog 


□ Log in 


Username 

Password 


Log In 


Not a user? Create an account now! 
>> Continue Shopping 


Valid users tor each application 
role include the following: 

Customer (CU5T): 

Username ngreenbe 
Password welcome 1 

Staff (STAFF): 

Username sking 
Password welcomel 

Supplier (SUPP): 

Username pbrown 
Password welcomel 


d. Enter ngreenbe and welcomel in the Username and Password fields, 
respectively. 

e. Click Log In. 

The Shipping Details page is displayed (Figure 4). 


2 























Figure 4 Shipping Details Page 


v Shipping Details 

2d Customer Information 


General Information 

Primary Address 

Customer Name Nancy Greenberg 

Address Line 1 2549 Yonge Street 

Member Since 

City Toronto 

Email Address NGREENBE 

Postal Code or ZIP M4P 2H9 

Mobile Phone 

State / Province ON 

865.555.0102 865.555.0102 

Country CA 


Order Summary 

Treo 650 Phone/PDA 
Cell Phones 

299.99 -quantity: 1 
Bluetooth Phone Headset 

Cell Phones 

49.99 -quantity: 1 


Order Information - #1347 



Shipping Information 

Payment Options 


Ship to I 

Payment 4111111111111111 VISA 

Option 


Shipping 10Q N peach st ph^delphia PA 19139 US ▼ 3 

Address 

Code 


Phone | 

Number 



Shipping Options 

Discounts 


Shipping Option Code ® Standard Shipping (3-5 business days) 

© Two-Day Shipping 

0 One-Day Shipping 
© Pick-up 

Coupon Code 


Gift Options 



Gift Wrapping Message None 




Items: *349.98 
Shipping & Handling *15.13 
Discounts *20.00 
Your Total: *345.11 

Submit Order | 


f. In the Order Information #order_id section, take note of the order ID, as you 
need it for a later task. In this example, the order ID is 1347. 

g. In the Shipping Information section, take note of the following default 
settings: 

-100 N Peach St Philadelphia PA 19139 US 
- 4111111111111111 VISA 

h. In the Order Summary section, take note of the order total, which is $345.11, 
and click Submit Order to complete the first order. 

The Invoice Details page is displayed (Figure 5). 


Figure 5 Invoice Details Page 


id Invoice Details 


id Customer Information 

General Information 

Primary Address 

Title 

Address Line 1 2549 Yonge Street 

First Name Nancy 

Address Line 2 

Last Name Greenberg 

City Toronto 

Confirmed Email Address NGREENBE 

Postal Code or ZIP M4P 2H9 

Phone 865.555.0102 

State / Province ON 

Mobile Phone 

Country CA 


2d Order Information 


General Information 

Payment Method 

Order Date 4/19/2010 

Account Number 4111111111111111 

Order Status PENDING 

Card Type VISA 

Invoice Total *345.11 

Expiration Date 14-MAR-2Q12 16:16:56 

Shipping Information 

Billing Address 

Ship to 

Address Line 1 100 N Peach St 

Address Line 1 100 N Peach St 

Address Line 2 

Address Line 2 

City Philadelphia 

City Philadelphia 

Postal Code or ZIP 19139 

Postal Code or ZIP 19139 

State / Province PA 

State / Province PA 

Country US 

Country US 


Phone Number 



2ll Line Items 


Name 

| List Price 

ShippingCost 

| Quantity 

Bluetooth Phone Headset 

49.99 

3.15 

1 

Treo 650 Phone/PDA 

299.99 

11.98 

1 
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3. Click the Exit and Continue Shopping link, located in the menu bar, to return to 
the home page (Figure 6). 

Figure 6 Exit and Continue Shopping Link 


A Exit and Continue Shopping 


4. Place an order for over $2000: 

a. Click Add under 20-Inch iMac for $2,499.99. 

The Shopping Cart Summary section displays a subtotal purchase total of 
$2,499.99 for the two items that appear in the cart. 

b. Click the Checkout link. 

The Shipping Details page is displayed. 

c. In the Order Information #order_id section, take note of the order ID, as you 
need it for a later task. In this example, the order ID is 1348. 

d. In the Shipping Information section, modify the default address to 2100 S 
Casino Dr. Laughlin NV 89029 US. 

If you decide to modify the other options, note the following about the credit 
card you select from the Payment Option Code list: 

- If the selected credit card is not AMEX, VISA, MSTR, or DINC, the 
OrderProcessor process faults with an invalid credit card type. For example, if 
you place an order with 123456765432 Western States Bank, the order faults. 

- If the selected credit card starts with 0,1, 2, or 3, the OrderProcessor process 
returns the status specified in Table 1. For example, selecting 378282246310005 
AMEX triggers a fraud alert. 


Table 1 Invalid Credit Card Number 


Credit Card Starting Number 

Status 

0 

INVALID 

1 

DENIED 

2 

STOLEN 

3 

FRAUD ALERT 


Later, after you have completed the procedures in this tutorial, you can select 
an invalid credit card to see the faults in the OrderProcessor process. 

e. In the Order Summary section, take note of the order total, which is $2,507.49, 
and click Submit Order to complete the second order. 

The Invoice Details page is displayed (Figure 7). 
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Figure 7 Invoice Details Page 


ill Invoice Details 

m Customer Information 


General Information 

Primary Address 

Title 

Address Line 1 2549 Yonge Street 

First Name Nancy 

Address Line 2 

Last Name Greenberg 

City Toronto 

Confirmed Email Address NGREENBE 

Postal Code or ZIP M4P 2H9 

Phone 865.555.0102 

State / Province ON 

Mobile Phone 

Country CA 


ml Order Information 

General Information 

Payment Method 

Order Date 4/19/2010 

Account Number 4111111111111111 

Order Status PENDING 

Card Type VISA 

Invoice Total *<2,507.49 

Expiration Date 14-MAR-2012 16:16:56 

Shipping Information 

Billing Address 

Ship to 

Address Line 1 100 N Peach St 

Address Line 1 2100 S Casino Dr 

Address Line 2 

Address Line 2 

City Philadelphia 

City Laughlin 

Postal Code or ZIP 19139 

Postal Code or ZIP 89029 

State / Province PA 

State / Province NV 

Country US 

Country US 

Phone Number 



ml Line Items 

Name 

| List Price 

IshippingCost 

| Quantity 

20-Inch iMac 

2499.99 

27.5 

1 


5. Click the Logout link, located in the right-hand-side of the menu bar, to log 
ngreenbe out of the session (Figure 8). 


Figure 8 Logout Link 


A Welcome Customer ngreenbe *4 Logout 


Task 2: Start Fusion Middleware Control to Monitor Orders 

To start Fusion Middleware Control to monitor orders: 

1. Use Mozilla FireFox, version 2.0 or higher, or Internet Explorer, version 7.0 or 
higher, to access the following URL: 

http:/ /hostname:port /em 

where hostname is the host name and port is the port of Fusion Middleware 
Control for the Oracle SOA Suite installation. 

The login dialog appears. 

2. Enter weblogic /password and click Login, 
where: 

■ weblogic is the Fusion Middleware Control administrator user name 

■ password is the password you provided for the weblogic administrator 
during installation 

3. From the navigation pane, expand SOA > soa-infra > soaFusionOrderDemo to 
see the deployed applications (Figure 9): 
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Figure 9 SOA Menu 


□ §| Farm_fod_domain 

E Q Application Deployments 
□ SOA 

□ j§§ soa-infra {soa_serverl) 

(0 default 

□ 10] soaFusionOrderDemo 

B2BX IZOrderGateway [1,0] 

OrderBookingComposite [1.0] 
ofS OrderSDOComposite [1.0] 
o)tS PartnerSupplierGomposite [1.0] 

E E~] WebLogic Domain 
E £T] Metadata Repositories 
E El User Messaging Service 

OrderBookingComposite and PartnerSupplierComposite are the two main 
composites in the WebLogic Fusion Order Demo application. 

4. Click the OrderBookingComposite composite. 

The home page for the SOA composite application is displayed (Figure 10). The 
upper part of the page displays details about recent SOA composite application 
instances, recent faults, and rejected messages. The topmost two instances in the 
Recent Instances table represent the instances of the SOA composite application 
you created when you placed the two orders in "Task 1: Place Two Orders in the 
Store Front" earlier. 

Figure 10 Recent Instances Section 


£> OrderBookingComposite [1.0] ® L °99 ed in as webfogic| Host 

SOA Composite t Page Refreshed Apr 19, 2010 3:03:14 PM PDllCij 

Running Instances 0 j Total 6 | Active Retire... Shut Down... Test ▼ Settings.,. ▼ » 

Dashboard Instances Faults and Rejected Messages UnitTests Policies 

® - 

E Recent Instances 


Show Only Running Instances 
Instance ID Name 
30020 
30017 


Running 0 

Conversation ID State 



Total 6 

Start Time 
Apr 19, 2010 2:59:54PM 
Apr 19, 2010 2: 57:29 PM 


Task 3: Monitor the First Order 

You now monitor the first order sent from the Store Front module to the 
OrderBookingComposite composite from Fusion Middleware Control. You submitted 
this order as Nancy Greenberg for $345.11. 

To monitor the first order: 

1. In the Recent Instances section, click the second instance, representing the first 
order for $345.11. Note the instance number. In this example, the instance number 
is 30017. 

The Flow Trace page is displayed. 

The Faults table displays details about faults occurring in the services, service 
components, and references that comprise SOA composite applications. If you 
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select an invalid credit card type or number, then the Faults section displays those 
faults. 

The Sensors table (Figure 11) displays details about composite sensors included in 
the service and reference binding components of the SOA composite application. It 
displays the following sensors: 

■ The CreditCardAuthResultSensor sensor tracks whether or not the 
CreditCardAuthorization service in the OrderBookingComposite composite 
approves the credit card. The value is APPROVED. 

■ The FulfillmentBatchlnsert sensor tracks the ID of the purchase order to 
fulfillment. The value is the value of the order ID returned in Step 2 in "Task 1: 
Place Two Orders in the Store Front" earlier. In this example, the value is 1347. 


Figure 11 Sensors Table 


*f* Sensors (2) 

Sensors 

Composite Sensors for this flow. 

Composite Instance Sensor Name Value Location Action 

30017 CreditCardAuthResultSensor APPROVED CreditCardAuthorizationServio AuthorizeCredit 

30017 ^ FulfillmentBatchlnsert 1347 FulfillmentBatch Produce_Message 


The Trace table (Figure 12) shows the sequence of the message flow through the 
services, service components, and references that comprise the SOA composite 
application. Because the OrderPendingEvent mediator receives the order and 
routes the input order ID to the OrderProcessor BPEL process, the instance is 
listed as OrderPendingEvent. 


Figure 12 Trace Section for the First Order 

Trace 

Click a component instance to see its detailed audit trail. 

Show Instance IDs O 


Instance 

Type 

Usage 

State 


E ** NewOrderSubmitted 

Event 


Completed 

Apr 19, 

E ^ OrderPendingEvent 

Mediator Component 


Completed 

Apr 19, 

E A OrderProcessor 

BPEL Component 


Completed 

Apr 19, 

StoreFrontService 

Web Service 

Reference 

Completed 

Apr 19, 

StoreFrontService 

Web Service 

**£3 Reference 

Completed 

Apr 19, 

^ CreditCardAuthorizationService 

Web Service 

“t9 Reference 

Completed 

Apr 19, 

RequiresApprovalRule 

Decision Service Component 

Completed 

Apr 19, 

InternalWarehouseService 

BPEL Component 


Completed 

Apr 19, 

E ^ PartnerSupplierMediator 

Mediator Component 


Completed 

Apr 19, 

E PartnerSupplierService 

Web Service(Local Invocatio °£9 Reference 

Completed 

Apr 19, 

externalpartnersupplier_dient_ep 

Web Service(Local Invocatio ^ Service 

Completed 

Apr 19, 

E ■*§: PartnerSupplierMediator 

Mediator Component 


Completed 

Apr 19, 

A ExternalPartnerSupplier 

BPEL Component 


Completed 

Apr 19, 

^ EvaluatePreferredSupplierRule 

Decision Service Component 

Completed 

Apr 19, 

^ StoreFrontService 

Web Service 

®£9 Reference 

Completed 

Apr 19, 

B FulfillOrder 

Mediator Component 


Completed 

Apr 19, 

USPSShipment 

JCA Adapter 

“£9 Reference 

Completed 

Apr 19, 

FulfillmentBatch 

JCA Adapter 

°£9 Reference 

Completed 

Apr 19, 

BAM_OrderDO 

JCA Adapter 

®£9 Reference 

Completed 

Apr 19, 

BAM_ProcessTimeDO 

JCA Adapter 

*59 Reference 

Completed 

Apr 19, 

StoreFrontService 

Web Service 

®t9 Reference 

Completed 

Apr 19, 


Notice how all the service components have a status of Completed for the first 
order. 

2. Click the OrderProcessor BPEL process service component in the Instance column 
to see how the first order was processed. 

The Audit Trail tab of the Instance of OrderProcessor window (Figure 13) displays 
execution details about the activities in the BPEL process. 
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Figure 13 Activity Trail Tab 


Flow Trace > Instance of OrderProcessor 

Data Refreshed Apr 19, 2010 4:20:58 PM PDT() 

^Instance of OrderProcessor ® 

This page shows BPEL process instance details. (?) 

Instance ID bpek30014 


Started Apr 19, 2010 237:34 PM 

Audit Trail Flow Sensor Values Faults 


Expand a payload node to view the details. 

Current Audit Level: production © View Raw XML 

B <process> 


B <scopename=main> 

B receivelnput 


B Apr 19, 2010 2:57:35 PM Received "inputVariable" call from partner "orderprocessor_dient_ep‘ 

View XML Document 

B cscope name=Scope_RetrieveOrder> 


B <sequence> 


B 4H findOrderByld 


Apr 19, 2010 2:57:36 PM 

bpelx:bindEnbty is executed on variable gOrderlnfbVariable with the following key values: {{/orade/fodemo/storefront/store/queries/common/}OrderId=1347} 

B QQAsskjnJVariableForSensor 


Apr 19, 2010 2:57:36 PM 

Updated variable TTmpOrderlnfoVariable' 

Apr 19, 2010 2:57:36 PM 

Completed assign 

B <scope name=Scope_RetrieyeCustomerForOrder>: 

B <sequence> 

B QQAssignCustomerld 


Apr 19, 2010 2:57:36 PM 

Updated variable TFindCustomerInfo_InputVariable" 

Apr 19, 2010 2:57:36 PM 

Updated variable iFindCustomerlnfbJnputVariable* 

Apr 19, 2010 2:57:36 PM 

Updated variable TFmdCustomerlnfoJnputVariable' 

Apr 19, 2010 2:57:36 PM 

Updated variable IFindCustomerlnfbJnputVariable" 

Apr 19, 2010 2:57:36 PM 

Updated variable IFindCustomerlnfbJnputVariable' 

Apr 19, 2010 2:57:36 PM 

Completed assign 

B 44$ InvokeFindCustomer 


B Apr 19, 2010 2:57:37 PM 

Invoked 2-way operation 'findCustomerlnfbVOlCustomerlnfbVOCriteria' on partner 'StoreFrontService'. 

B <payload> 


f=l x'crAno AnfknmoT 


4 \ III 1 ► 

4 \ III | ► 


3. Click the Flow tab to see a visual representation of the instance. 

A visual representation of the BPEL process activities appears (Figure 14). The 
icons in the flow are referred to as activities. You can click them to view their 
details. 

Figure 14 Flow Tab with BPEL Process Activities 


Flow Trace > Instance of OrderProcessor 

^Instance of OrderProcessor© 

This page shows BPEL process instance details. (*) 

Audit Trail Flow Sensor Values Faults 
Qick an activity to view the details. 



receivelnput 


Data Refreshed Apr 19, 2010 4:20:58 PM PDT( ) 

Instance ID bpeb30014 

Started Apr 19, 2010 2:57:34 PM 


Current Audit Level: production ® 


View Raw XML 



5 Scope_RetrieveOrder 


findOrderByld 

findOrderByld 


BQ 

l_U 

AssignjVaria... 


O Scope_RetrieveCustomerForOrder 


FI 


4. Click the first activity, the blue, circle receive activity labeled receivelnput 
(Figure 15). 
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Figure 15 receivelnput Activity 



The Activity Audit Trail dialog displays the XML input to this BPEL process 
instance (Figure 16). If you click the View xml document link, it shows the order 
ID (orderlD) you were given when you placed the order through the Store Front 
module. In this example, the order ID is 1347. 

Figure 16 receivelnput in Activity Audit Trail Dialog 


— <dieut:process> 

<chemt:o rd e rld> 1547 </die ut: o rd e ild> 
</dient:p ro c e s s> 


5. Click X to dismiss the XML output. 

6. Click X or Close to dismiss the Activity Audit Trail dialog. 

7. Scroll further in the process to the Scope_RetrieveOrder activity and click 
findOrderBylD to view the order ID as input to variable gOrderlnfoVariable: 

bpelxibindEntity is executed on variable gOrderlnfoVariable with the following 
key values: 

{{/oracle/fodemo/storefront/store/queries/common/}0rderld=1347} 

8. Click X or Close to dismiss the Activity Audit Trail dialog. 

9. Scroll to the Scope_RetrieveCustomerForOrder scope and click the 
InvokeFindCustomer activity to see the StoreFrontService service being invoked 
and returning the customer information. Note the following in the Activity Audit 
Trail dialog: 

■ lFindCustomerInfo_InputVariable represents the input variable to the 
StoreFrontService service. The Custld parameter represents the ID of 
customer ngreenbe. In this example, the ID is 108. 

■ gCustomerlnfoVariable represents the output from the StoreFrontService 
service, which returns the customer information back to the BPEL process 
(Figure 17). 
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Figure 17 InvokeFindCustomer Activity in Activity Audit Trail Dialog 


osj| InvokeFindCustomer 

j [201Q/04/19 14:57:37] 

Invoked 2-way operation "findCustomerlnfoVOlCustomerlnfoVOCriteria" on partner "StoreFrontService". 

; - <rnessages> 

- -= I Fi n d Custo m erl nfo_I n putVa ri a bl e > 

- -cpart na me= " p a ra meters" xmlns:xsi="http:/ /www.w3.org/2001/XMLSchema-instance"> 

- -cf i n d Custo m e rl nf o VO 1 Custo marl nf o VO Crite ri a xml ns= " www. g I o b a I co m p a ny. example.com/ types / " > 

- <findCriteria> 

cfetchStart xmlns="http://xmlns.oracle.com/ adf/svc/types/">-l-=/fetchStart> 

<fetchSize xmlns="http:/ /xmlns.oracle.com/adf/svc/types/ ">l-=:/fetchSize> 

<excl ud eAttri bute xm I ns= " http : / / xm I ns. o ra cl e. co m / adf / svc/ typ es / " > fal se </■excl udeAttri bute > 
</findCriteria> 

< Custld > 10 S </CustI d > 

- <findControl> 

■=: retrieveAl IT ra nslations xmlns="http://xmlns.ora cle.com/adf/svc/types 
/ " := fal se -:/retri e veAl IT ra nslati o ns> 

I </findControl> 

</f i n d Custo me rl nfoVO 1 Custo me rl nfoVO Crite ria > 

-=:/part> 

; -=/l Find Custo me rl nf o_I n putVa ria ble > 

- eg Custo me rl nfoVa ria ble > 

- epart name="parameters" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> 

- < nsO: f i n d Custo m e r I nfoVO 1 Custo m e rl nfoVO Crite ria Response 

xmlns: nsO="www.glob alcompany.example.com/types/" xml ns: wsa=" http://www.w3.org/20 05/08 
/ addressing" > 

- ensO:result xmlns:nsl="/ oracle/fodemo/storefront/store/queries/common/" 

xml ns :nsO= "www.globalcompany.example.com/types/" xmlns :xsi="http:// www.w3.org 
/ 2001/XMLSchema-instance" xsi :tvpe="nsl:CustomerInfoVOSDO"> 

ensl:PersonId=-loae/nsl:PersonId> 

< nsl: Fi rstN a m e >Nancy < / nsl: Fi rstN a m e > 

e nsl: LastN a m e >Gr«£aibeirg-=: / n s 1: LastN a m e > 

< nsl: Co nf i rrned Email > NGEEENBE </ns 1: Co nf i rm e d E m a i I > 
ensl:MobilePhoneNumber xsi:nil="true"/> 

e nsl: M e m be rsh i pI d xsi: n i I = "tru e"/> 

< nsl: M em be rsh i pTy pe Co d e xsi: n i I = "tru e ' V> 

</nsO:result> 

; </ns0:findCustomerInfoVOlCustomerI nfoVO Crite ria Response > 

e/part> 

e/g Custo me rl nfoVa ri a bl e > 

; -=:/messages> 


10. Click X or Close to dismiss the Activity Audit Trail dialog. 

11. Scroll to the Scope_AuthorizeCreditCard scope and click 
InvokeCheckCreditCard to see the CreditCardAuthorization service being 
invoked and returning the status of the credit card. 

Note the following in the Activity Audit Trail dialog: 

■ lCreditlnput represents the input variable to the 
CreditCardAuthorizationService service. Parameters CCType, CCNumber, 
and PurchaseAmount represent the input credit card type, number, and order 
total. These values are set as follows: 

<CCType>VISA</CCType> 

<CCNumber>4111111111111111</CCNumber> 

<PurchaseAmount>345.ll</PurchaseAmount> 

■ lCreditCardOuput shows that the service returned a status of APPROVED. 
Therefore, the OrderProcessor BPEL process continues. 

12. Click X or Close to dismiss the Activity Audit Trail dialog. 

13. Scroll to the Scope_CheckApprovalLimit scope and click the Invoke link under 
BusinessRule_ApprovalRequired to see the RequiresApprovalRule business 
rule being invoked. 

Note the following in the Activity Audit Trail dialog (Figure 18): 

■ dsln represents the input variable sent to the business rule. The approve 
parameter shows the invocation of the business rules engine at run time. The 
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price parameter shows the order total was $345.11. The business rules engine 
requires this input to determine whether human approval is required. 

■ dsOut shows the output from the business rule. The approvalRequired 

parameter has a value of false. Because this order is under $2,000, no human 
approval is required. Therefore, the return value is set to false. 

Figure 18 Invoke Activity for BusinessRuleApprovalRequired Scope in Activity Audit 
Trail Dialog 

J® Invoke 

j [2010/04/1914:57:39] 

Invoked 2-way operation "callFunctionStateless" on partner 
"RequiresApprovalRule_QracleRulesl_DecisionService_l'\ 

1 - <messages:> 

- <dsln> 

- -cpart name="payload" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"> 

- cnsO:callFunctionStateless name="'OracleRulesl_DecisionService_l" xmlns=" http://xmlns.oracle.com 
/RequiresApprovalRule/OracleRulesl_DecisionService_l" ximIns :nsO="http://xmlns.oracle.com 
/bpel/rules" := 

cconfigURL xmlns=" http://xmIns.oracle.com/bpel/rules"/ > 

- <parameterl_ist xmlns="http:/ /xmlns.oracle.com/bpel/rules" > 

- ^approve xmlns="http:/ /www.globalcompanv.example.com/ns/OrderBookingService/rules" > 

<prioe>345. ll</price> 

-ca ppro v a I Re q u i re d ^ fal se</a ppro va I Re q u i re d > 

; </a p prove > 

</pa ra m ete rList> 

</nsO:callFundtionStateless> 

; c/part> ; 

-=/dsIn> 

- -=dsQut> 

- -cpart name="payload" xmlns:xsi="http://www.w3.org/2001/XHLSchema-instance"> 

- cnsO:callFunctionStatelessDecision xmlns="http://xmlns.oracle.com/bpel/rules" 
xmlns: ns2="http://xmlns.oracle.com/bpel" xmlns:nsO=" http://xmlns.oracle.com 
/RequiresApprovalRule/OracleRulesl_DecisionService_l"> 

- -cresultList xmlns="http:/ /xmlns.oracle.com/RequiresApprovalRule 
/ O ra cl e Ru I es 1_D e cis i o nSe rvi ce_l " > 

- <approve:approve xmlns: approve="http://www.globalcompany.example.com 
/ns/OrderBookingService/rules" xml ns="http://www.globalcompany.example.com 
/ns/OrderBookingService/rules" > 

■=price>345. llc/price> 

< a pp ro va I Re q u i re d > fal ae< / a ppro va I Re q u i re d > 

I </approve: approver I 

</resultList> 

; </nsO': ca 11 Fu nctionStatelessDecision > 

c/part> 

</dsOut> 

; </messages> ; 


14. Click X or Close to dismiss the Activity Audit Trail dialog. 

15. In the Scope_RetrieveQuotes scope, perform the following: 

a. Click the Invoke_PartnerSupplier link to see the order information being sent 
to the PartnerSupplierMediator mediator (Figure 19). The 
PartnerSupplierMediator mediator routes the order information to the 
ExternalPartnerSupplier BPEL process, located in the 
PartnerSupplierComposite composite. 
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Figure 19 lnvoke_PartnerSupplierActivity in Activity Audit Trail Dialog 


Invoke_PartnerSupplier 


[2010/04/19 14:57:39] 

Invoked 1-way operation "execute" on partner "PartnerSupplierMediator". 

- <lPartnerSupplierInputVariable> 

- <part name="request" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"- 

- corderlnfoVOSDO xmlns:ns2="http://xmlns.oracle.com/adf/svc/types/" xmlns:nsO="/oracle/fodemo/storefront/store 
/queries/common/" xmlns:xsi="http:// www.w3.org/2001/XMLSchema-instance" xmlns="/oracle/fodemo/storefront 
/store/queries/common/" > 

<n.s0:0rderld>l347</ns0:0rderld> 

<ns0 :OrderDate>20l0-04-l9T08: oo: oo. 0Z</ns0: OrderDate> 

<nsO:OrderShippedDate xsi:nil="true",’> 

<nsO:OrderStatusCode:= PENDING =:/nsO:OrderStatusCode> 

<nsO:OrderTotal>345. H</nsO:OrderTotal> 

<ns0:CustomerId>l08</ns0:CustomerId> 

<nsO:ShipToName xsi:nil="true"'> 

<nsO:ShipToPhoneNumber xsi:nil="true’7> 

<ns0:AddressId>3</ns0:AddressId> 

<nsO:Addressl>100 N Peach St</ns0:Addressl> 

<nsO:Address2 xsi:nil="true"/> 

<ns0: City- Philadelphia </ns0: City> 

<ns0:PostalCode>l9l39</ns0:PostalCode> 

<ns0: StateProvince>PA</nsO: StateProvince> 

< nsO: Countryld >US</nsO: CountryId> 

<ns0: PaymentOptionId>l00l</ns0: PaymentOptionId> 

<ns0:BillingAddressId>3</ns0:BillingAddressId> 

<ns0:AccountNumber>4111111111111111</ns0:AccountNumber> 

<ns0: CardTypeCode >VlSA</ns0: CardTypeCode> 

<ns0: ExpireDate>2012-03-15T00:16:56.0Z</ns0: ExpireDate> 

<ns0:CheckDigits>333</ns0:CheckDigits> 

<nsO:RoutingIdentifier xsi:nil=''true" > 

<ns0:InstitutionName xsi:nil="true".> 

<ns0:ShipToAddressId>3</ns0:ShipToAddressId> 

< nsO: ObjectVersionld >2 </ns0: ObjectVersionld > 

<nsO:ShippingOptionId>l</nsO:ShippingOptionId> 

< nsO: ObjectVersion Id 1 > 0 </ns0: ObjectVersionld 1 > 

<nsO:FreeShippingFlag>N</nsO:FreeShippingFlag> 

<nsO:ObjectVersionId2>0</nsO:ObjectVersionId2> 

<nsO:CustomerCollectFlag>N</nsO:CustomerCollectFlag> 

< nsO: Giftwra pFlag >Y</nsO: GiftwrapFlag > 

<ns0: PaymentOptionIdl>lOOl</nsO: PaymentOptionIdl> 

- <nsO:OrderItemsInfoVO> 


b. Click X or Close to dismiss the Activity Audit Trail dialog. 

c. Click the Invoke_InternalWarehouse link to see the order being sent to the 
InternalWarehouseService BPEL process through the 
llnternalWarehouselnputVariable variable (Figure 20): 


Figure 20 InvokeJnternalWarehouse in Activity Audit Trail Dialog 

In vo ke_Inte rn a IW a re ho use 

; [2010/04/19 14:57:39] 

Invoked 1-way operation "process" on partner "InternalWarehouseService". 

| - <IInternalWarehouseInputVariable> 

- -cpart name="payload" xmlns:x5i="http://www.w3.org/2001/XHLSchema-instance"=- 
- -=Wa re ho use Re quest xnnlns= "http://www.globalcompany.example.com 
/ns/InternalWarehouse":= 

■=orderId>l347-=/orderId> 

I -=/WarehouseRequest> 

<=/part> 

; ^/l I ntern a I Wa re ho use I n putVa ri a bl e =- 

d. Click X or Close to dismiss the Activity Audit Trail dialog. 

16. In the Scope_SelectPreferredSupplier scope, click the Invoke link under 
BusinessRule_SelectPreferredSupplier to see the 
EvaluatePreferredSupplierRule business rule being invoked. 

Note the following in the Activity Audit Trail dialog: 

■ dsln represents the input variable sent to the business rule. The warehouse, 
deliveryDate, and orderTotal parameter values provide the input to the 
business rule. The business rules engine uses this input to pick the supplier 
with the lowest shipping price to fulfill the order. 
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The input data for the two warehouse suppliers displays in Example 1. 


Example 1 Input Data for Quotes from the Warehouses 

<nsl:warehouse>PartnerWarehouse</nsl:warehouse> 

<nsl:deliveryDate>2010-04-19</nsl:deliveryDate> 

<nsl:orderTotal>345.ll</nsl:orderTotal> 


<warehouse>InternalWarehouse</warehouse> 

<de1iveryDate>2 010 — 04 —19</deliveryDate> 

<orderTotal>1000</orderTotal> 

The InternalWarehouse supplier returns a static value of $1,000 for all orders. 

■ dsOut shows the output from the business rule (Example 2). The warehouse 
parameter value shows the selected warehouse supplier. The 
PartnerWarehouse supplier was selected because it provided a lower quote. 

Example 2 Output Data for Quotes from Warehouses 

<warehouse>PartnerWarehouse</warehouse> 

<nsl:deliveryDate>2010-04-19</nsl:deliveryDate> 

<nsl:orderTotal>345.ll</nsl:orderTotal> 

17. Click X or Close to dismiss the Activity Audit Trail dialog. 

18. In the Scope_FulfillOrder scope, click the Invoke_FulfillOrder link to see the 
order information being sent to the FulfillOrder mediator (Figure 21). The 
FulfillOrder mediator stores the order in a temporary queue and routes the order 
to USPS for shipment. 

Figure 21 lnvoke_FulfillOrder Activity in Activity Audit Trail Dialog 

■J# Invoke_FulfillOrder 

I [2D10/04/19 14:57:413 

Invoked 1-way operation "execute" on partner "FulfillOrder.FulfillOrder". 

; - < I Fulfil lOrd er_InputVari able > 

- -cpart name=" request" xmlns:xsi="http://www.w3.Qrg/2001/XMLSchema-instance"> 

- <orderInfoVOSDO xmlns:ns2="http://xmlns.oracle.com/adf/svc/types/" xmlns:nsO="/oracle/fodenno 
/storefront/store/queries/common/" xmlns:xsi="http://www.w3.org/2O01/XMLSchema-instance" 
xmlns="/oracle/fodemo/storefront/store/queries/comm on/ "> 

<ns0:0rderld>l347</ns0:0rderld> 

<nsO:OrderDate>2 Dl□ -□ 4-19TD& : 00 : qo. oz,</nsO:OrderDate> 

<nsO: Orders hipped Date xsi:nil="true"/> 

< nsO: 0 rde rStatusCo de >PEND lNG</nsO: Orde rStatusCo d e > 

<nsO:OrderTotal>345. ll</nsG:OrderTotal> 

<nsO:CustomerId>lDB</nsO:CustomerId> 

<nsO:ShipToName xsi:nil="true" > 

-cnsOiShipToPhaneNumber xsi:nil="true" > 

c nsO: Add ressld >3 </ns 0: Add ressld > 

<nsO:Addressl>100 N Peach st</nsO :Addressl> 

<nsO:Address2 xsi:nil="true" > 
nsO: City > Phi ladelphia </nsO: City> 
c nsO: Posta I Cod e > l S 13 9-=/nsO: Posts I Cod e > 

< nsO: State Provi n ce /nsO: State Pr o vi n ce > 

< nsO:Oou rttry Id >US </nsO: Co u ntryld > 

< ns 0: Pay m e ntO pti o n I d > l □ □ l < /ns 0: Pay m e ntO pti o n I d > 

-=nsO: Bi 11 i ng Add ressld >3</nsO: BillingAddressId> 
cns0:AccountNumber>41llillilillilil</ns0:AoDOuntNumber> 

-=nsO: CardTypeCode >VlSA=/nsO: CardTypeCode> 

<nsO:ExpireDate>2ai2-03-l5TOO: 16:56. o.B</nsO:ExpireDate> 

< nsO: CheckD i g its > 333</nsO:Che ekD i g its> 

< nsO: R .0 uti n g I d e ntifi e r xsi: n i I ="tru e"/ > 

<nsO:InstitutionName xsi:nil="true"/> 

< nsO: S h i pToAd d ressld >3 </nsO: Shi pToAd d ressld > 

< nsO: O bjectVe rsi on Id >2 </nsO: O bjectVe rsi o n I d > 

<nsO:ShippingOptionId>l</nsO:ShippingOptio'nId> 

■c nsO: n hi p :rfVfi rsi nn Trl 1 > n </ n.sfl: Ohi r dVs i n n T H1 > 
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19. Click X or Close to dismiss the Activity Audit Trail dialog. 

20. Scroll to the Scope_NotifyCustomerOfCompletion scope and click the 
InvokeNotificationService link to see the NotificationService service being used 
to send an e-mail notification to Nancy Greenberg. 

21. Click X or Close to dismiss the Activity Audit Trail dialog. 

22. Click the Sensors tab to view the sensors for the BPEL process. 

23. In the Instance of OrderProcessor window, click X or Close to dismiss the window. 

Task 4: View the Second Order in Fusion Middleware Control 

You now monitor the second order you submitted for $2,507.49 as Nancy Greenberg. 
This order is processed differently than the first order, because the order amount is for 
more than $2,000. Therefore, it requires human approval. To monitor the second order 
with Fusion Middleware Control, approve the order with Oracle BPM Worklist, and 
see the order completed in Fusion Middleware Control. 

To view the second order in Fusion Middleware Control: 

1. In the Recent Instances section, click the first instance, representing the second 
order for $2,507.49. Note the instance number. In this example, the instance 
number is 30020. 

The Flow Trace page is displayed. 

The Sensors table (Figure 22) displays the following sensors: 

■ The CreditCardAuthResultSensor sensor tracks whether or not the 
CreditCardAuthorization service in the OrderBookingComposite composite 
approves the credit card. For this order, the value is APPROVED. 

■ The AssignedUserForApprovalSensor sensor sends the assignee to approve 
the order for the instance 30020. Because this order was over $2,000, it requires 
human approval. The assignee information is sent to the Oracle BAM Server. If 
you click the View XML link, you can see the assignee is user jstein. 

Figure 22 Sensors Table 

| Sensors (2) 

Sensors 

Composite Sensors for this flow. 

Composite Instance Sensor Name Value Location Action 

30020 (( f : ' AssignedUserForApprovalSensor View XML... BAM_ProcessTimeDO_ECID writetoBAM 

30020 CreditCardAuthResultSensor APPROVED CreditCardAuthorizationServio AuthorizeCredit 

The Trace table (Figure 23) shows the sequence of the message flow through the 
order. 
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Figure 23 Trace Table for the Second Order 


Trace 

Click a component instance to see its detailed audit trail. 
Show Instance IDs □ 


Instance 

Type 

Usage 

State 

□ * - NewOrderSubmitted 

Event 


Completed 

E ^ OrderPendingEvent 

Mediator Component 


Running 

□ OrderProcessor 

BPEL Component 


Running 

StoreFrontService 

Web Service 

^ Reference 

Completed 

'ijj StoreFrontService 

Web Service 

^ Reference 

^ Completed 

^ CreditCardAuthorizationService 

Web Service 

^ Reference 

Completed 

C^j RequiresApprovalRule 

Decision Service Component 


^ Completed 

B cfe ApprovalHumanTask 

Human Workflow Componenl 


Running 

E ^ OrderApprovalTaskAssignedMediator 

Mediator Component 


Completed 

£§ BAM_ProcessTimeDO_ECID 

JCA Adapter 

Reference 

# Completed 


Unlike the first order, notice in the Trace table how the service components are not 
all complete and the process is stopped at the ApprovalHumanTask component. 

2. Click the OrderProcessor BPEL process service component in the Instance column 
to see how the first order was processed. 

3. In the Instance of OrderProcessor window, click the Flow tab to see a visual 
representation of the instance. 

4. Click the receivelnput activity to see the order ID you placed. 

The Activity Audit Trail dialog displays the XML input to this BPEL process 
instance. If you click the View xml document link, it shows the order ID (orderlD) 
you were given when you placed the order through the Store Front module. In this 
example, the order ID is 1348. 

5. Click X to dismiss the XML output. 

6. Click X or Close to dismiss the Activity Audit Trail dialog. 

7. Scroll to the Scope_CheckApprovalLimit scope and click the Invoke link under 
BusinessRule_ApprovalRequired to see the RequiresApprovalRule business 
rule being invoked. 

Note the following in the Activity Audit Trail dialog (Figure 24): 

■ dsln represents the input variable sent to the business rule. The approve 
parameter shows the invocation of the business rules engine at run time. The 
price parameter shows the order total was $2,507.49. 

■ dsOut shows the output from the business rule. The approvalRequired 
parameter has a value of true. Because this order is over $2,000, human 
approval is required. Therefore, the return value is set to true. 
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Figure 24 Invoke Activity for BusinessRuleApprovalRequired Scope in Activity Audit 
Trail Dialog 


Invoke 

; [2010/04/19 14:59:55] 

Invoked 2-way operation "callFunctionStateless'’ on partner , ’RequiresApprovalRule_OradeRulesl_DecisionService_l". 

; - <messages> 

- <dsln> 

- <part name="payload" xmln5:xsi="http:/Zwww.w3.org/2001/XMLSchema-instance"> 

- <nsO:callFunctionStateless name="OracleRules IDecisionServicel" xmlns="http:/ /xmlns.oracle.com 
/RequiresApprovalRule/OracleRulesl_DecisionService_l" xmlns: nsO="http://xmlns.orade.com/bpel/rules" > 

<oonfigURL xmlns="http:/ /xmlns.oracle.com/ bpel/ rules"/ > 

- <parameterList xmlns="http://xmlns.oracle.com/bpel/rules"> 

- ^approve xmlns="http://www.globalcompany.example.com/ns/OrderBookingService/rules"> 

<price>2ED7.4»</price> 

< a pprova I Re q u i re d > Fal ae< /a p prove I Re q u i re d > 

I -=/approve> 

</pa ra meterList> 

; </nsO:callFunctionStateless> 

</part> 

</dsIn> 

- <dsOut> 

- <part name="payload" xmlns:xsi="http://www.w3.org/2001/XMI_Schema-instance"> 

- <nsO: callFunctionStatelessDecision xmlns="http:/ /xmlns.oracle.com/ bpel/ rules" 

xmlns: ns2="http://xmlns.oracle.com/bpel" xmlns: nsO="http://xmlns.oracle.com/RequiresApprovalRule 
/OracleRulesl_DecisionService_l' r > 

- <resultLi=t xmlns="http:/ /xmlns.oracle.com/ RequiresApprovalRule/ OracleRulesl_DecisionService_l"> 

- <approve: approve xmlns:approve="http://www.globalcompany.example.com/ns/ OrderBookingSeivice/rules" 
xmlns="http://www.globalcompany.exaniple.com/ns/OrderBookingService/rules"> 

<price>2ED7.49</pnce> 

< a pprova I Re q u i re d >tme</a pprova I Re q u i re d > 

I -=:/approve: approve > 

</resultList> 

; -=/nsO: cal I Function StatelessDecision> 

I </part> 

</dsOut> 

; </messages> 


8. Click X or Close to dismiss the Activity Audit Trail dialog. 

9. Click the Collapse icon (-) icon on BusinessRule_ApprovalRequired to collapse 
it. 

10. Scroll toward the bottom of the Scope_CheckApprovalLimit scope to see that the 
ApprovalHumanTask human task was initiated after the business rule (Figure 25). 
The switch under the business rule is like an if-then-else, case, or switch 
statement in other programming languages. In this case, if approval is required, 
this switch submits data to the ApprovalHumanTask human task. 
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Figure 25 Scope_CheckApprovaiLimit in Flow Trace 


i 



switchNode (438) 


Q ApprovalHunnanTask_l (446) 



ApprovalHuman... 



receiveComple... 


11. Click the initiateTask_ApprovalHumanTask_l activity. 

12. In the Activity Audit Trail dialog, scroll to the initiateTaskResponseMessages 
variable to see the assigneeUsers parameter. This parameter specifies that the 
human task has been assigned to user j stein, as shown in Example 3. 

Example 3 assigneeUser Parameter 

<assigneeUsers> 

<id>jstein</id> 

<displayName>John Steinbeck</displayName> 

<type>user</type> 

</assigneeUsers> 

13. Click X or Close to dismiss the Activity Audit Trail dialog. 

14. Click the receiveCompletedTask_ApprovalHumanTask_l activity to see that the 
human task is awaiting approval (Figure 26). 

Figure 26 receiveCompletedTask_ApprovalHumanTask_ 1 Activity in Activity Audit Trail 

Dialog 


re ce ive Co m p I etedTa sk_Ap p rova IH u m a nTa sk_ 1 

: [2010/04/19 14:59:57] 

Waiting for '’onTaskCornpleted" from "TaskService". Asynchronous callback. 


[2010/04/19 14:59:57] 

Changes in entity variable "gOrderlnfoVariable"' have been saved back through the 
back-end service 
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15. Click X or Close to dismiss the Activity Audit Trail dialog, but do not close the 
Instance of OrderProcessor window, as you need it to view order processing as it 
completes. 


Task 5: Use Oracle BPM Worklist to Approve the Order 

To use Oracle BPM Worklist to approve the order: 

1. Use Internet Explorer 7 or Mozilla Firefox 2.0.0.2 to access the following URL: 

http:/ /hostname:port/ integration/worklistapp/faces/home.j spx 

where hostname is the DNS name or IP address of the Oracle WebLogic Server 
for Oracle SO A Suite and port is the address of the port on which the managed 
server for the Oracle WebLogic Server is listening for requests (8 0 01 by default). 

The login dialog appears. 

2. Enter j stein in the Username field and we 1 cornel in the Password field, and 
click Login. 

3. The Inbox shows the order number is awaiting approval. Figure 27 shows order 

1348. 


Figure 27 BPM Worklist: Inbox 


ORACLE’ BPM Worklist 


^ I Worklist Views + </ X 

R Inboxl 

V c£> My Work Queues 
V Standard Views 

QU Due Soon 
d] High Priority 
OH Past Day 
[HI Past Week 
(H Past Month 
d] Past Quarter 
01] New Tasks 
My Views 

V sjj> Proxy Work Queues 

Shared Views 


Home Reports Preferences Help Logo 


My Tasks 


Initiated Tasks My Staff Tasks Administration Tasks 


Actions ▼ Assignee Me & Group ▼ Status Assigned ▼ Search Advanced 

Title | Number Priority Assignees State j Created 

(ID Order approval for order (1348) 200020 3 jstein (U) Assigned Apr 19, 2010 2:59 PM 


4. Select the order from the table and view the order details in the lower portion of 
the page (Figure 28). 
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Figure 28 BPM Worklist: Order Details 


My Tasks 
Actions ▼ 


Initiated Tasks My Staff Tasks Administration Tasks 


Assignee Me a Group t Status Assigned 


t Search 


Advanced 


Title 

Number 

[Priority 

Assignees 

(state | Created |e 

[Hi Order approval for order (1348) 

200020 

3 

istein (U) 

Assigned Apr 19 r 2010 2: 59 PM 

< i 

rrr 



- 


Order approval for order (1348) 

0 ^ Details 


Actions T Approve Reject 


□Order Information 

Order Id 1348 


OrderStatusCode 

PENDING 

OrderTotal 

2507.49 

ShipToName 

ShipToPhoneNumber 

Address 1 

2100 S Casino Dr 

Address2 

City 

Laughlin 

PostalCode 

89029 

StateProvince 

NV 

Countryld 

US 


Order Lines . Order Historv 


5. Approve the order. From the Actions menu, select Approve (Figure 29). 

Figure 29 BPM Worklist: Actions Menu 


Actions T Approve Reject 


The My Tasks tab updates so that no worklist tasks are currently assigned to 
j stein. 

With the order approval completed, the processing for the order is now complete. 

Task 6: View the Approval in Fusion Middleware Control 

To verify the order completed processing with Fusion Middleware Control: 

1. Return to the Instance of OrderProcessor window, and click the Refresh icon, 
located in the top right corner (Figure 30). 

Figure 30 Refresh Icon 

cs 

2. Scroll toward the bottom of the Scope_CheckApprovalLimit scope to see the 
ApprovalHumanTask human task (Figure 31). 
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Figure 31 ApprovaIHumanTask 


l-l_Appro va I H u m a nTask_l 



Approval Human... 



receive Com pie... 


3. Click the receiveCompletedTask_ApprovalHumanTask_l activity to see the 
human task (Figure 32). 

Figure 32 receiveCompletedTask_ApprovalHumanTask_ 1 


@ receive Com pi etedTask_AppravalHumanTask_l 

j [2010/04/19 14:59:57] 

Waiting for "onTaskCompleted" from "TaskService". Asynchronous callback. 


[2010/04/19 14:59:57] 

Changes in entity variable "gOrderlnfoVariable"' have been saved back through the 
back-end service 


[2010/04/19 17:10:31] 

Received '’onTaskCompleted" callback from partner "TaskService" 
re view xml document 


4. Click X or Close to dismiss the Activity Audit Trail dialog. 

5. In the Scope_SelectPreferredSupplier scope, click the Invoke link under 
BusinessRule_SelectPreferredSupplier to see the 
EvaluatePreferredSupplierRule business rule being invoked. 

Note the following in the Activity Audit Trail dialog: 

■ dsln represents the input variable sent to the business rule. The warehouse, 
deliveryDate, and orderTotal parameter values provide the input to the 
business rule. The business rules engine uses this input to pick the supplier 
with the lowest shipping price to fulfill the order. 

Example 4 shows the returned input data for the two warehouse suppliers: 

Example 4 Data from Warehouses 

<nsl:warehouse>PartnerWarehouse</warehouse> 

<nsl:deliveryDate>2010-04-19</deliveryDate> 

<nsl:orderTotal>2499.99</orderTotal> 
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<warehouse>InternalWarehouse</warehouse> 

<deliveryDate>2 010 —04—19</deliveryDate> 

<orderTotal>1000</orderTotal> 

■ dsOut shows the output from the business rule. The warehouse parameter 
value shows the selected warehouse supplier. The InternalWarehouse 
supplier was selected because it provided a lower quote. 

6. Click X or Close to dismiss the Activity Audit Trail dialog. 

7. In the Instance of OrderProcessor window, click the Flow Trace bread crumb to 
return to the main Flow Trace window. 

Notice in the Trace section how the service components in the 
OrderBookingComposite composite are now all complete (Figure 33). 

Figure 33 Trace Section 


Trace 

Click a component instance to see its detailed audit trail. 
Show Instance IDs □ 


Instance 

Type 

Usage 

State 

Time 

B M NewOrderSubmitted 

Event 


Completed 

Jan 10, 2011 1:45:06 PM 

E ^ OrderPendingEvent 

Mediator Component 


Completed 

Jan 10, 2011 2:35:44 PM 

B A OrderProcessor 

BPEL Component 


^ Completed 

Jan 10, 2011 2:35:44 PM 

StoreFrontService 

Web Service 

Reference 

Completed 

Jan 10, 2011 1:45:06 PM 

StoreFrontService 

Web Service 

*f9 Reference 

Completed 

Jan 10, 2011 1:45:06 PM 

CreditCardAuthorizationService 

Web Service 

“£9 Reference 

Completed 

Jan 10, 2011 1:45:06 PM 

^ RequiresApprovalRule 

Decision Service Component 


& Completed 

Jan 10, 2011 1:45:06 PM 

StoreFrontService 

Web Service 

*£9 Reference 

Completed 

Jan 10, 2011 2:19:59 PM 

StoreFrontService 

Web Service 

°f9 Reference 

Completed 

Jan 10, 2011 2:20:00 PM 

E 3a ApprovalHumanTask 

Human Workflow Componeni 


<<& Completed 

Jan 10, 2011 2:35:40 PM 

^ StoreFrontService 

Web Service 

*£8 Reference 

Completed 

Jan 10, 2011 2:35:40 PM 

B ^ PartnerSupplierMediator 

Mediator Component 


Completed 

Jan 10, 2011 2:35:42 PM 

E PartnerSupplierService 

Web Service(Local Invocatio 

*|9 Reference 

Completed 

Jan 10, 2011 2:35:40 PM 

A InternalWarehouseService 

BPEL Component 


Completed 

Jan 10, 2011 2:35:42 PM 

EvaluatePreferredSupplierRule 

Decision Service Component 


Completed 

Jan 10, 2011 2:35:43 PM 

^ StoreFrontService 

Web Service 

*f9 Reference 

Completed 

Jan 10, 2011 2:35:43 PM 

E ^ FulfillOrder 

Mediator Component 


Completed 

Jan 10, 2011 2:35:44 PM 

^ StoreFrontService 

Web Service 

*£9 Reference 

Completed 

Jan 10, 2011 2:35:44 PM 

ft OrderCompleted 

Event 


Completed 

Jan 10, 2011 2:35:45 PM 


8. Click on any additional service components to view the audit trail. For example, if 
you want to view audit trail information for how a mediator transforms data, click 

PartnerSupplierMediator or FulfillOrder. 

9. Close the Flow Trace window. 

Documentation Accessibility 

For information about Oracle's commitment to accessibility, visit the Oracle 
Accessibility Program website at 

http://www.oracle.com/pls/topic/lookup?ctx=acc&id=docacc. 

Access to Oracle Support 

Oracle customers have access to electronic support through My Oracle Support. For 
information, visit 

http : / /www. oracle . com/pls/topic/lookup?ctx=acc&id=info or visit 
http://www.oracle.com/pls/topic/lookup?ctx=acc&id=trs if you are 

hearing impaired. 
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